package com.itheima.producer;

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

/**
 * 发送消息
 */
public class Producer_HelloWorld {
    public static void main(String[] args) throws IOException, TimeoutException {
        //1.创建连接工厂
        ConnectionFactory factory = new ConnectionFactory();

        //2. 设置参数
        factory.setHost("localhost");//ip  默认值 localhost
        factory.setPort(5672); //端口  默认值 5672
        factory.setVirtualHost("/lxl");//虚拟机 默认值/
        factory.setUsername("lxl");//用户名 默认 guest
        factory.setPassword("lxl");//密码 默认值 guest
        try (//3. 创建连接 Connection
             Connection connection = factory.newConnection();
             //4. 创建Channel
             Channel channel = connection.createChannel()) {


            /*
            queueDeclare(String queue, boolean durable, boolean exclusive, boolean autoDelete, Map<String, Object> arguments)
            参数：
                1. queue：队列名称
                2. durable:是否持久化，当mq重启之后，还在
                3. exclusive：
                    * 是否独占。只能有一个消费者监听这队列
                    * 当Connection关闭时，是否删除队列
                    *
                4. autoDelete:是否自动删除。当没有Consumer时，自动删除掉
                5. arguments：参数。

             */
            //5. 创建队列Queue，如果没有一个名字叫hello_world的队列，则会创建该队列，如果有则不会创建
            channel.queueDeclare("hello_world", true, false, false, null);

            //6. 发送消息
            String body = "hello rabbitmq~~~";
            /*
            basicPublish(String exchange, String routingKey, BasicProperties props, byte[] body)
            参数：
                1. exchange：交换机名称。简单模式下交换机会使用默认的 ""
                2. routingKey：路由名称
                3. props：配置信息
                4. body：发送消息数据
             */
            channel.basicPublish("", "hello_world", null, body.getBytes());
        }

    }
}
